From 0c52eca34cd1edeb51b930f756652e359ed6ee10 Mon Sep 17 00:00:00 2001 From: Matthias Clasen Date: Sun, 3 Jan 2016 14:02:00 -0500 Subject: [PATCH] Move node printing to GtkCssNodeDeclaration The node declaration has all the information we are printing here (except for visibility). At the same time, redo the format to print the information in selector format, and indicate (in)visibility by enclosing the selector in square brackets. --- gtk/gtkcssnode.c | 91 +++--------------------------- gtk/gtkcssnodedeclaration.c | 50 ++++++++++++++++ gtk/gtkcssnodedeclarationprivate.h | 4 ++ 3 files changed, 63 insertions(+), 82 deletions(-) diff --git a/gtk/gtkcssnode.c b/gtk/gtkcssnode.c index 916b83b685..a828d9f8e1 100644 --- a/gtk/gtkcssnode.c +++ b/gtk/gtkcssnode.c @@ -1523,80 +1523,6 @@ gtk_css_node_get_style_provider (GtkCssNode *cssnode) return GTK_STYLE_PROVIDER_PRIVATE (_gtk_settings_get_style_cascade (gtk_settings_get_default (), 1)); } -static void -append_id (GtkCssNode *cssnode, - GString *string) -{ - const char *id; - - id = gtk_css_node_get_id (cssnode); - if (id) - { - g_string_append (string, " id="); - g_string_append (string, id); - } -} - -static void -append_visible (GtkCssNode *cssnode, - GString *string) -{ - g_string_append_printf (string, " visible=%d", gtk_css_node_get_visible (cssnode)); -} - -static void -append_state (GtkCssNode *cssnode, - GString *string) - -{ - GtkStateFlags state; - - state = gtk_css_node_get_state (cssnode); - if (state) - { - GFlagsClass *fclass; - gint i; - gboolean first = TRUE; - - g_string_append (string, " state="); - fclass = g_type_class_ref (GTK_TYPE_STATE_FLAGS); - for (i = 0; i < fclass->n_values; i++) - { - if (state & fclass->values[i].value) - { - if (first) - first = FALSE; - else - g_string_append_c (string, '|'); - g_string_append (string, fclass->values[i].value_nick); - } - } - g_type_class_unref (fclass); - } -} - -static void -append_classes (GtkCssNode *cssnode, - GString *string) -{ - const GQuark *classes; - guint n_classes; - - classes = gtk_css_node_list_classes (cssnode, &n_classes); - if (n_classes > 0) - { - int i; - - g_string_append (string, " classes="); - for (i = 0; i < n_classes; i++) - { - if (i > 0) - g_string_append_c (string, ','); - g_string_append (string, g_quark_to_string (classes[i])); - } - } -} - static gboolean gtk_css_node_has_initial_value (GtkCssNode *cssnode, GtkCssStyleProperty *prop) @@ -1690,14 +1616,15 @@ gtk_css_node_print (GtkCssNode *cssnode, GtkCssNode *node; g_string_append_printf (string, "%*s", indent, ""); - if (gtk_css_node_get_name (cssnode)) - g_string_append (string, gtk_css_node_get_name (cssnode)); - else - g_string_append (string, g_type_name (gtk_css_node_get_widget_type (cssnode))); - append_id (cssnode, string); - append_visible (cssnode, string); - append_state (cssnode, string); - append_classes (cssnode, string); + + if (!cssnode->visible) + g_string_append_c (string, '['); + + gtk_css_node_declaration_print (cssnode->decl, string); + + if (!cssnode->visible) + g_string_append_c (string, ']'); + g_string_append_c (string, '\n'); append_style (cssnode, flags, string, indent + 2); diff --git a/gtk/gtkcssnodedeclaration.c b/gtk/gtkcssnodedeclaration.c index bc139ffe7a..78441c8cb0 100644 --- a/gtk/gtkcssnodedeclaration.c +++ b/gtk/gtkcssnodedeclaration.c @@ -648,3 +648,53 @@ G_GNUC_END_IGNORE_DEPRECATIONS gtk_widget_path_iter_set_state (path, pos, decl->state); } +/* Append the declaration to the string, in selector format */ +void +gtk_css_node_declaration_print (const GtkCssNodeDeclaration *decl, + GString *string) +{ + static const char *state_names[] = { + "active", + "hover", + "selected", + "disabled", + "indeterminate", + "focus", + "backdrop", + "dir(ltr)", + "dir(rtl)", + "link", + "visited", + "checked", + "drop(active)" + }; + const GQuark *classes; + guint i; + + if (decl->name) + g_string_append (string, decl->name); + else + g_string_append (string, g_type_name (decl->type)); + + if (decl->id) + { + g_string_append_c (string, '#'); + g_string_append (string, decl->id); + } + + classes = get_classes (decl); + for (i = 0; i < decl->n_classes; i++) + { + g_string_append_c (string, '.'); + g_string_append (string, g_quark_to_string (classes[i])); + } + + for (i = 0; i < G_N_ELEMENTS (state_names); i++) + { + if (decl->state & (1 << i)) + { + g_string_append_c (string, ':'); + g_string_append (string, state_names[i]); + } + } +} diff --git a/gtk/gtkcssnodedeclarationprivate.h b/gtk/gtkcssnodedeclarationprivate.h index a72111ab37..7760da17fb 100644 --- a/gtk/gtkcssnodedeclarationprivate.h +++ b/gtk/gtkcssnodedeclarationprivate.h @@ -72,6 +72,10 @@ gboolean gtk_css_node_declaration_equal (gconstp void gtk_css_node_declaration_add_to_widget_path (const GtkCssNodeDeclaration *decl, GtkWidgetPath *path, guint pos); + +void gtk_css_node_declaration_print (const GtkCssNodeDeclaration *decl, + GString *string); + G_END_DECLS #endif /* __GTK_CSS_NODE_DECLARATION_PRIVATE_H__ */ -- 2.30.2